Bookmark-Based Access to Content Feeds

ABSTRACT

A method executes at a computing device having one or more processors and memory. The memory stores one or more programs configured for execution by the one or more processors. The process analyzes content of a first content item provided by a first content feed against a first set of content-based labeling rules. The first content item is selected from among a set of unread content items of the first content feed to which a user of the computing device has subscribed. When it is determined that the first content item satisfies the first set of content-based labeling rules, the process automatically (without human intervention) assigns the first content label to the first content item and causes the first content label to be displayed concurrently with information identifying the first content item.

RELATED APPLICATIONS

This application is a continuation of U.S. patent application Ser. No. 14/612,102, filed Feb. 2, 2015, entitled “Content Feed User Interface with Gallery Display of Same Type Items,” which is a continuation of U.S. patent application Ser. No. 11/246,657, filed Oct. 7, 2005, entitled “Content Feed User Interface with Gallery of Display of Same-Type Items,” now U.S. Pat. No. 8,949,154, each of which is incorporated herein by reference in its entirety.

This application is related to the following U.S. patent applications, each of which is incorporated herein by reference in its entirety: U.S. patent application Ser. No. 11/246,596, entitled “Personalized Content Feed Suggestions Page,” now U.S. Pat. No. 8,190,997; U.S. patent application Ser. No. 11/246,656, entitled “Indirect Subscriptions to Top N Lists of Content Feeds,” now U.S. Pat. No. 7,590,691; and U.S. Pat. application Ser. No. 11/246,597, entitled “Indirect Subscriptions to A User's Selected Content Feed Items”.

TECHNICAL FIELD

The disclosed embodiments relate generally to content syndication, and more particularly, to a content feed user interface with a gallery display of content feed items of the same type.

BACKGROUND

Content syndication is growing in popularity as a way to distribute frequently updated information, such as news and blog postings, on the Internet. Using content syndication formats such as Really Simple Syndication (RSS), content providers can include content and/or links to such in a content feed. Users may subscribe to these content feeds using an application known as a reader or aggregator. When the content feed is updated with new content items, the new content items are reflected in the user's reader.

A user may subscribe to many content feeds, with each feed listing many content items. A user may be interested in content of particular types, such as images or videos, or content from particular sources and/or categories. Looking through the many listed content items to find the ones of the desired type can be a time-consuming and cumbersome task for the user.

Accordingly, there is a need for a more efficient manner of presenting content items to the user.

SUMMARY

In accordance with some embodiments, a method of presenting content includes presenting identifying information associated with a number of content items; upon user selection of one of the content items, identifying one or more additional content items that satisfy predefined criteria with respect to the selected content item; and presenting information corresponding to the selected and additional content items.

In some embodiments, the content items include RSS feed content items

In some embodiments, the aforementioned operations may be performed by a system having one or more processors, memory, and one or more modules, stored in the memory and configured for execution by the processors, with instructions to perform the aforementioned operations.

BRIEF DESCRIPTION OF THE DRAWINGS

FIG. 1 is a block diagram illustrating a content feed aggregation system in accordance with some embodiments.

FIG. 2 is a diagram illustrating a data structure of a content item and its corresponding metadata in accordance with some embodiments.

FIG. 3 is a flow diagram illustrating a process for displaying a gallery of content items in accordance with some embodiments.

FIG. 4 is a block diagram illustrating a client computer in accordance with some embodiments.

FIG. 5 is a block diagram illustrating a server computer in accordance with some embodiments.

FIG. 6 is a diagram illustrating a feed reader user interface with a universal view in accordance with some embodiments.

FIG. 7 is a diagram illustrating a feed reader user interface with a thumbnails gallery in accordance with some embodiments.

FIG. 8 is a diagram illustrating a feed reader user interface with a playlist gallery in accordance with some embodiments.

FIG. 9 is a diagram illustrating a feed reader user interface with a headlines gallery in accordance with some embodiments.

FIG. 10 is a diagram illustrating a feed reader user interface with a same source gallery in accordance with some embodiments.

Like reference numerals refer to corresponding parts throughout the drawings.

DESCRIPTION OF EMBODIMENTS

In a content feed aggregation system, a user may subscribe to one or more content feeds and be presented with the content items included in those content feeds. However, the user may be interested in particular types of content items. The disclosed embodiments provide the user a way to look for those particular types of content items. When a user selects a content item, the user is presented with a “gallery” of the selected content item and other content items that satisfy predefined criteria with respect to the selected item. The “gallery” provides the user a more efficient manner of presenting to the user content items of particular types.

FIG. 1 is a block diagram illustrating a content feed aggregation system in accordance with some embodiments. The content feed aggregation system 100 includes a server system 104. The server system 104 is coupled to one or more client systems 102 and to one or more hosts 120 (or “feed sources”) by a network 106. The network 106 may be any suitable wired and/or wireless network and may include a local area network (LAN), wide area network (WAN), the Internet, and so forth.

The server system 104 accesses content feeds from the feed sources 120. The server system 104 includes a server 108 and a database 110. Server 108 serves as a front-end for the server system 104. Server 108 retrieves the content feeds from the feed sources 120. The server 108 provides an interface between the server system 104 and the client systems 102.

The server system 104 stores content items in the content feeds in the database 110. In some embodiments, the database 110 stores both metadata (e.g., title, description, URL, date/time, and possibly other metadata) and the content of each content item. However, in some other embodiments, the database 110 stores the metadata but not the content for each content item. The database 110 also stores user feed information 112 for a plurality of users. The user feed information for a particular user identifies content feed subscriptions, as well as sources, filters, and read states for that particular user. That is, user feed information associated with a user identifies the content feeds to which the user has subscribed, any filters the user has defined for the feeds, any labels the user has associated with individual feed items, and an indication of whether each feed item has been marked as “read” by the user.

It should be appreciated that the server system 104, including the server 108 and the database 110, may be implemented as a distributed system of multiple computers. However, for convenience of explanation, the server system 104 is described below as being implemented on a single computer, which can be considered a single logical system.

A content feed (or channel) is a resource or service that provides a list of content items that are present, recently added, or recently updated at a feed source 120. A content item in a content feed may include the content associated with the item itself (the actual content that the content item specifies), a title and/or a description of the content, a locator (e.g., URL) of the content, or any combination thereof. For example, if the content item identifies a text article, the content item may include the article itself inline, along with the title and locator. Alternatively, a content item may include the title, description and locator, but not the article content. Thus, some content items may include the content associated with those items, while others contain links to the associated content but not the full content of the items. A content item may also include additional metadata that provides additional information about the content. The full version of the content may be any machine-readable data, including but not limited to web pages, images, digital audio, digital video, Portable Document Format (PDF) documents, and so forth. Further details regarding content items are described below, in relation to FIG. 2.

In some embodiments, a content feed is specified using a content syndication format, such as RSS. RSS is an acronym that stands for “rich site summary,” “RDF site summary,” or “Really Simple Syndication.” RSS may refer to any of a family of formats based on the Extensible Markup Language (XML) for specifying a content feed and content items included in the feed. In some other embodiments, other content syndication formats, such as the Atom syndication format or the VCALENDAR calendar format, may be used to specify content feeds.

Further information regarding the RSS syndication format known as “Really Simple Syndication” is disclosed in the RSS 2.0 Specification by D. Winer, which is hereby incorporated by reference herein in its entirety. M. Nottingham et al. disclose further information regarding the Atom syndication format in The Atom Syndication Format, which is hereby incorporated by reference herein in its entirety.

A user interfaces with the server system 104 and views content items at a client system or device 102 (hereinafter called the client system for ease of reference). The client system 102 includes a computer 118 or computer controlled device, such as a person digital assistant, cellular telephone or the like (hereinafter called the client system for ease of reference). The computer 118 typically includes one or more processors (not shown); memory, which may include volatile memory (not shown) and non-volatile memory such as a hard disk drive 119; and a display 114. The computer 118 may also have input devices such as a keyboard and a mouse (not shown).

In some embodiments, a user may interact with the server system 104 via a feed reader user interface 116 that may be presented on the display 114. The user may create a list of feed subscriptions via the feed reader user interface 116. In some embodiments, using the feed reader user interface 116, the user may also create filters or labels to be applied to content feeds and/or content items, and modify the read states of content feeds and/or content items. The feed reader user interface transmits a list of content feed subscriptions, or modifications to a list of content feed subscriptions, to the server system 104 for storage at the database 110. The feed reader user interface 116 presents content items stored at the database 110 to the user based on the user's list of content feed subscriptions. That is, feed reader user interface 116 presents to the user content items specified in the content feeds to which the user has subscribed. A user may view the full version of the content of a content item in the feed reader user interface 116 by selecting it (e.g., by clicking on it with a mouse pointer). In some embodiments, a copy of the user's list of content feed subscriptions and copies of the presented content items may be cached locally at the client system 102.

In some embodiments, the feed reader user interface 116 may be a web-based user interface. That is, the feed reader user interface 116 displays one or more web pages in one or more browser (e.g., web browser) windows. The web pages may be written in the Hypertext Markup Language (HTML), Extensible Markup Language (XML), or any other suitable language for preparing web pages, and may include one or more scripts for interfacing with the server system 104. The user may subscribe to content feeds, view content items, and otherwise interact with the server system 104 by interacting with the web pages of the feed reader user interface 116. In other words, the server system 104, and the web pages transmitted by the server system 104 to the feed reader user interface 116, provides a web-based content aggregation service. The server system 104 aggregates and stores content items in accordance with the user's content feed subscriptions. In some embodiments, the server system 104 also can apply filters or labels, or change the read states of content items in accordance with user actions or instructions. When the user accesses the feed reader user interface 116, content items to which the user has subscribed are presented to the user via the feed reader user interface 116.

In some other embodiments, the feed reader user interface 116 may be a part of a standalone application that is run on the client system 102. The standalone application may interface with the servers system 104 via an application programming interface (API).

FIG. 2 is a diagram illustrating a data structure of a content item and its corresponding metadata in accordance with some embodiments. A content feed may include one or more content items. Each content item, in turn, includes information about the full version of the content and possibly the full version itself The information may be contained in one or more fields. A content item 200 may include a title 202 of the content item. A location 204 of the content item identifies a location of the full version of the content. In some embodiments, the location 204 is the Uniform Resource Locator (URL) of the full version of the content. In some other embodiments, other forms of location identifiers or addresses may be used to identify the location of the full version of the content.

A content field 206 may include a synopsis or description of the full version of the content, an excerpt from the content, or the full version itself The full version of the content may be any machine readable data, such as text, graphics, digital audio, digital video, a Portable Document Format (PDF) file, and so forth.

In some embodiments, the full version of the content may be an enclosure to the content item. In the content item data structure, the enclosure may be specified by an enclosure location that identifies the location of the enclosure. In some embodiments, the enclosure location is the URL of the enclosure. The data structure may also include a size field for specifying the size of the enclosure (e.g., in number of bytes), and a data type field to identify the type of the enclosure. The data type may identify the data category of the enclosure, the file type of the enclosure, or both. For example, if the enclosure is a JPEG image file, the data type may specify that the enclosure is an “image”, that the enclosure is a JPEG file, or that the enclosure is an “image” of the JPEG file type. In some embodiments, the data type may be specified using the Multipurpose Internet Mail Extensions (MIME) standard, which is well-known in the art and need not be further described.

The content item 200 may include one or more metadata fields 208. For example, the content item may include a source identifier 210 to identify the source content feed of the content item, an author name or identifier 212 to identify the author of the particular content item, and a publication date 214 to identify the date on which the content item was published.

It should be appreciated that the data structure for the content item 200 and the described fields are merely exemplary. A content item may include a subset of the fields identified above, may include additional fields, and may take on alternative formats.

Attention is now directed to FIG. 3, which is a flow diagram illustrating a process for displaying a gallery of content items in accordance with some embodiments. While the process flow 300 described below includes a number of steps or operations that appear to occur in a specific order, it should be apparent that these processes can include more or fewer steps or operations. Some of the operations that are described here as being executed serially may be performed in parallel (e.g., using parallel processors or a multi-threading environment). Furthermore, in some embodiments, some of the operations (e.g., operations 302-304) may be performed multiple times before a following operation (e.g., operation 306) is performed.

A plurality of content items is received (302). The received content items are specified in content feeds to which the user has subscribed. In some embodiments, the content items are provided by the server system 104 (FIG. 1) to the client system 102 (FIG. 1).

Identifying information associated with the received content items are displayed (304). In some embodiments, the identifying information is displayed as a list of content items in the feed reader user interface 116 (FIG. 1). In some embodiments, the feed reader user interface 116 may have a finite display area. In such circumstances, identifying information for a subset of the received content items may be in view at a given time. The user may scroll through the list to view identifying information associated with other received content items. The list may display all or a subset of the content item fields. For example, the displayed identifying information may include the titles and the source content feeds of the content items. In some embodiments, the identifying information that is displayed (that is, the fields that are displayed) may be configured by the user.

In some embodiments, the list includes content items from all subscribed feeds. This may be referred to as the “universal” view, or an interleaved list. That is, content items from the subscribed content feeds are all displayed in the same list and not separated by source. In some embodiments, the list may be sorted by the publication date and time of the content item, for example in reverse chronological order. In some other embodiments, the user may toggle an option to display a universal view, to display the items ordered by source, author, or some other field, or to display only content items from a particular source, by a particular author, or the like.

The user selects a content item from the list (306). The user may select a content item by clicking on the content item with a mouse pointer or by using keyboard commands.

In response to the selection, other content items in the list satisfying predefined criteria with respect to the selected content item are identified (308). In some embodiments, other content items that are the same as the selected content item with respect to a set of predefined characteristics are identified. Thus, the predefined criteria may require content items to match one or more characteristics of the selected content items. That is, additional content items are identified based on matches to a particular set of characteristics of the selected item. For example, additional content items having the same data type and source content feed as the selected item are identified. In some embodiments, the characteristics that serve as criteria for identifying additional content items may be configured in advance by the user.

In some embodiments, an exemplary characteristic for identifying additional content items is the data type of the full version of the content of a content item. When the user selects a content item and the content item includes content such as an image, digital audio, or digital video, additional content items also having an image, digital audio, or digital video are identified, respectively. In some embodiments, the identification may be based on the data category, such as whether the object is an image, digital audio, etc. The data category may be explicitly specified by the content item or inferred from the file type of the content. For example, if the content item includes an MPEG digital video, other content items that includes a file of any file type recognized as digital video (such as QUICKTIME, WINDOWS MEDIA, REALVIDEO, etc.) may be identified. In some other embodiments, the identification may be based on the specific file type, rather than data categories. For example, if the content item includes a JPEG image, other content items including a JPEG image, but not images of other file types such as GIF or TIFF images, may be identified.

Another exemplary characteristic for identifying additional content items is that the additional content items follow the same format as the selected content item, in that if the selected content item includes a title 202 (FIG. 2) and a location 204 (FIG. 2) but no content 206 (FIG. 2), then the additional content items must also each have a title and a location but no content. This criterion may be helpful in identifying content items that include headlines (in the title) and links to the articles having the headlines.

It should be appreciated that data type and format are merely exemplary characteristics on which other content items may be identified. Other characteristics, including but not limited to source, author, and/or publication date (or a publication date range), may be used as identification criteria. Furthermore, any combination of the characteristics may be used as the identification criteria. For example, the identification criteria may be that the additional content items must have the same data type and the same source as the selected content item.

Information corresponding to the selected content item and the identified additional content items are presented to the user (310). The information is displayed in a “gallery” view. The gallery view includes a collection of information for each of the selected and additional content items (or at least a subset of the selected and additional content items, due to finite display regions). The gallery view provides a preview of the selected and additional content items. The gallery view gives the user an at-a-glance look of the selected and additional content items. From the gallery view, the user may select a content item for viewing.

In some embodiments, the information that is displayed in the gallery may depend at least in part on the identification criteria. For example, if the identification criteria include having the same data type, then the information that is displayed may be information that is related to the data type of the selected and additional content items. Further information regarding the gallery view and the information that is displayed in the gallery view is described below, in relation to FIGS. 6-10.

FIG. 4 is a block diagram illustrating a client computer in accordance with some embodiments. The client computer 400 typically includes one or more processing units (CPU's) 402, one or more network or other communications interfaces 406, memory 404, and one or more communication buses 414 for interconnecting these components. The client computer 400 may also include a user interface 408 comprising a display device 410 and a keyboard and/or mouse (or some other pointing device) 412. Memory 404 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices. Memory 404 may optionally include one or more storage devices remotely located from the CPU(s) 402. Memory 404, or alternatively one or more non-volatile solid state storage devices within memory 404, includes a computer readable storage medium. In some embodiments, memory 404 stores the following programs, modules and data structures, or a subset thereof:

-   -   an operating system 416 that includes procedures for handling         various basic system services and for performing hardware         dependent tasks;     -   a network communication module 418 that is used for connecting         the client system 400 to other computers via the one or more         communication network interfaces 406 and one or more         communication networks, such as the Internet, other wide area         networks, local area networks, metropolitan area networks, and         so on; and     -   a feed reader module 420 for handling content items from content         feeds; and     -   a client application 430, such as a web browser.

The feed reader module 420 includes a content item identification module 422 that identifies additional content items satisfying predefined criteria with respect to a user-selected content item. The feed reader module 420 also includes a gallery module 424 for presenting information corresponding to the selected and additional content items in a gallery view.

In some embodiments, the feed reader module 420 may be a script-based module, embedded in a web page served from the server system 104 (FIG. 1). The web page may be rendered by a client application 430, such as a web browser, at the client computer 400. When the web page is rendered, the feed reader module 420 is executed, thereby providing a web-based interface to the server system 104. The script-based feed reader module may be written in JavaScript, ECMAScript or any other suitable scripting language.

In some other embodiments, the feed reader module 420 may be a standalone application stored in memory 404 of the client computer 400. The standalone application may include, but is not limited to a feed aggregator application. In further other embodiments, the feed reader module 420 may be an add-on or a plug-in to another application. For, example, the feed reader module 420 may be a plug-in to an email application.

In some embodiments, received content items may be cached locally in memory 404. Similarly, a user's list of content feed subscriptions may also be cached locally in memory 404.

Each of the above identified elements may be stored in one or more of the previously mentioned memory devices. Each of the above identified modules corresponds to a set of instructions for performing a function described above. The above identified modules or programs (i.e., sets of instructions) need not be implemented as separate software programs, procedures or modules, and thus various subsets of these modules may be combined or otherwise re-arranged in various embodiments. In some embodiments, memory 404 may store a subset of the modules and data structures identified above. Furthermore, memory 404 may store additional modules and data structures not described above.

FIG. 5 is a block diagram illustrating a server computer in accordance with some embodiments. The server computer 500 typically includes one or more processing units (CPU's) 502, one or more network or other communications interfaces 506, memory 504, and one or more communication buses 510 for interconnecting these components. The server system 500 optionally may include a user interface 508, which may include a display device (not shown), and a keyboard and/or a mouse (not shown). Memory 504 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices. Memory 504 may optionally include one or more storage devices remotely located from the CPU(s) 502. Memory 504, or alternatively one or more non-volatile solid state storage devices within memory 404, includes a computer readable storage medium. In some embodiments, memory 504 stores the following programs, modules and data structures, or a subset thereof:

-   -   an operating system 512 that includes procedures for handling         various basic system services and for performing hardware         dependent tasks;     -   a network communication module 514 that is used for connecting         the server system 500 to other computers via the one or more         communication network interfaces 506 and one or more         communication networks, such as the Internet, other wide area         networks, local area networks, metropolitan area networks, and         so on;     -   a feed tracker module 516 for retrieving content items for         storage periodically and/or as content feeds are updated;     -   user data 518, which includes data for each user of the service;         and     -   content items 520, which include retrieved content items from         content feeds to which users of the service have subscribed.

The user data 518 stores data for users of the service, such as login information and user preferences. The user data 518 includes subscription lists 519, which include lists of users' feed subscriptions. Each user has a corresponding list of content feed subscriptions. In some embodiments, the server computer 500 may further store feed subscription information in one or more tables (both not shown). The feed subscription information tables store information associated with content feeds, such as the locations of the feeds (e.g., the feeds' URLs) and per-user subscription information with respect to individual content feeds.

Each of the above identified elements may be stored in one or more of the previously mentioned memory devices, and corresponds to a set of instructions for performing a function described above. The above identified modules or programs (i.e., sets of instructions) need not be implemented as separate software programs, procedures or modules, and thus various subsets of these modules may be combined or otherwise re-arranged in various embodiments. In some embodiments, memory 504 may store a subset of the modules and data structures identified above. Furthermore, memory 504 may store additional modules and data structures not described above.

Although FIG. 5 shows a “server computer,” FIG. 5 is intended more as functional description of the various features which may be present in a set of servers than as a structural schematic of the embodiments described herein. In practice, and as recognized by those of ordinary skill in the art, items shown separately could be combined and some items could be separated. For example, some items shown separately in FIG. 5 could be implemented on single servers and single items could be implemented by one or more servers.

FIG. 6 illustrates a feed reader user interface with a “universal view” in accordance with some embodiments. The user, via the feed reader user interface 116, may view, among other things, content items from her subscribed content feeds. The feed reader user interface 116 (hereinafter the “UI”) includes one or more buttons, menus, links, and the like 610 for activating and deactivating various functions and features.

The user may view the content items in a universal view. The universal view includes a list 602 of content items from all of the user's subscribed feeds. The content items 604 shown in the list are interleaved without regard to source. In some embodiments, the list is sorted by publication date and time, for example in reverse chronological order. Also, in some embodiments, the list may show only content items that the user has not viewed. The list presents identifying information for the content items, so that the user can identify a content item she wishes to view and select it. Because the UI 116 may have a finite size and the list may include more items than can fit into the UI, the UI 116 may display a subset of the content items at a given time and the user may scroll through the list to find other content items. The list may also include an indicator 606 of how many content items are in the list in total. Alternatively, the indicator 606 may indicate the number of content items yet to be viewed.

From the list, the user may select a content item. When the user selects an item from the list in the universal view, the UI 116 may display the full version of the content in a viewer region 608. For example, if the selected content item (indicated by a box with a thick border) includes a link to an article at a news web site or a link to a blog posting, the article or the blog posting, respectively, may be displayed in the viewer region 608.

In the UI 116, a gallery feature may be enabled. When the feature is enabled and a content item is selected from the list 602, instead of displaying the full version of the content in the viewer region 608, a gallery view of information corresponding to the selected content item 605, FIG. 7, and additional content items may be displayed in the viewer region 608.

When the selected content item includes an image, the information that is displayed in the gallery view includes thumbnails of the selected content item and additional content items that also include images, as illustrated in FIG. 7. In some embodiments, the additional content items are all from the same content feed as the selected item. In other embodiments, the additional content items may include content items from the same content feed as the selected item as well as content items from different content feeds. For each of the selected content item and additional content items, the gallery view presents a thumbnail 702 and information 704 corresponding to the image, such as a name of the image (which may be derived from the title of the content item or the file name) and a size (which may be the size of the image file or the dimensions of the image in pixels). The user may select one of the thumbnails in the viewer region 608 to open the image in the viewing region or in a new window.

When the selected content item (e.g., content item 607 in FIG. 8) includes digital video or digital audio, the information that is displayed in the gallery view includes a playlist of the video or audio clips, respectively, of the selected content item and additional content items, as illustrated in FIG. 8. As in the example discussed above with respect to FIG. 7, in some embodiments the additional content items are all from the same content feed as the selected item, while in other embodiments the additional content items may include content items from the same content feed as the selected item as well as content items from different content feeds. In some embodiments, for each of the selected content item and additional content items, the gallery view presents a title of the clip 802 (which may be derived from the title of the content item, the file name of the clip, or metadata embedded in the clip) and a running time 804 of the clip. The user may select one of the clips in the viewer region 608 to access the clip and playback controls for the clip.

In some embodiments, the gallery view may display information corresponding to a selected content item and additional, identified content items, when the selected content item and the identified content items include a title and link to the full version of the content but no content itself, as illustrated in FIG. 9. That is, the identification criterion is that if the selected content item 609 includes a title and location but no actual content, then additional content items that follow the same pattern of having a title and a location but no actual content are identified. The viewer region 608 shows the title of each of the selected and additional content items as a headline 902 of the content item and, optionally, a date 904 of each content item. In other embodiments, the gallery of content items may be displayed in a number of different ways, for example using a grid instead of a list. The user may select one of the content items in the viewer region 608 to access the full version of the content to which the content item links.

In some embodiments, additional content items from the same source content feed as the selected content item 611 may be displayed in the gallery view, as shown in FIG. 10. Titles 1002 and dates 1004 of the selected and additional content items may be displayed in the viewer region 608. The user may select one of the content items in the viewer region 608 to access the content item.

The foregoing description, for purpose of explanation, has been described with reference to specific embodiments. However, the illustrative discussions above are not intended to be exhaustive or to limit the invention to the precise forms disclosed. Many modifications and variations are possible in view of the above teachings. The embodiments were chosen and described in order to best explain the principles of the invention and its practical applications, to thereby enable others skilled in the art to best utilize the invention and various embodiments with various modifications as are suited to the particular use contemplated. 

What is claimed is:
 1. A method, comprising: at a computing device having one or more processors and memory storing one or more programs for execution by the one or more processors: analyzing content of a first content item provided by a first content feed against a first set of content-based labeling rules, wherein the first content item is selected from among a set of unread content items of the first content feed to which a user of the computing device has subscribed; responsive to a determination that the first content item satisfies the first set of content-based labeling rules: automatically without human intervention: assigning the first content label to the first content item; and causing the first content label to be displayed concurrently with information identifying the first content item.
 2. The method of claim 1, further comprising: automatically without human intervention: assigning the first content label to the first content feed; and causing the first content label to be displayed concurrently with information identifying the first content feed.
 3. The method of claim 1, wherein the first content feed provides a first plurality of content items, and further comprising: automatically without human intervention: assigning the first content label to the first plurality of content items.
 4. The method of claim 1, further comprising: responsive to a predefined user action with respect to the first content item: assigning a second content label to the first content item; and causing the first content label and the second content label to be displayed concurrently with information identifying the first content item.
 5. The method of claim 4, wherein the first content label identifies a first property of the content of the first content item, the second content label identifies a second property of the content of the first content item, and the second property is distinct from the first property.
 6. The method of claim 1, wherein the first content label is a graphic label.
 7. The method of claim 1, wherein the first content label is a text label.
 8. The method of claim 1, wherein the first content label is a user-customized label.
 9. The method of claim 1, wherein the first content label is a system-provided label.
 10. The method of claim 1, wherein the information identifying the first content item includes a title of the first content item.
 11. The method of claim 1, wherein the information identifying the first content item includes a snippet of the first content item.
 12. The method of claim 1, further comprising: responsive to a predefined user action with respect to the first content label: identifying a plurality of content items associated with the first content label.
 13. The method of claim 12, wherein the plurality of content items includes the first content item provided by the first content feed, and a second content item provided by a second content feed.
 14. The method of claim 1, further comprising: responsive to a predefined user action with respect to the first content label: identifying a plurality of content feeds associated with the first content label.
 15. A computing system, comprising: one or more processors; memory; and one or more programs, wherein the one or more programs are stored in the memory and configured to be executed by the one or more processors, the one or more programs including instructions for: analyzing content of a first content item provided by a first content feed against a first set of content-based labeling rules, wherein the first content item is selected from among a set of unread content items of the first content feed to which a user of the computing device has subscribed; responsive to a determination that the first content item satisfies the first set of content-based labeling rules: automatically without human intervention: assigning the first content label to the first content item; and causing the first content label to be displayed concurrently with information identifying the first content item.
 16. The system of claim 15, wherein the one or more programs further comprise instructions for: automatically without human intervention: assigning the first content label to the first content feed; and causing the first content label to be displayed concurrently with information identifying the first content feed.
 17. The system of claim 15, wherein the first content feed provides a first plurality of content items, and the one or more programs further comprise instructions for: automatically without human intervention: assigning the first content label to the first plurality of content items.
 18. A non-transitory computer readable storage medium storing one or more programs for execution by the one or more processors of a client system, the one or more programs including instructions for: analyzing content of a first content item provided by a first content feed against a first set of content-based labeling rules, wherein the first content item is selected from among a set of unread content items of the first content feed to which a user of the computing device has subscribed; responsive to a determination that the first content item satisfies the first set of content-based labeling rules: automatically without human intervention: assigning the first content label to the first content item; and causing the first content label to be displayed concurrently with information identifying the first content item.
 19. The non-transitory computer readable storage medium of claim 18, wherein the one or more programs further comprise instructions for: automatically without human intervention: assigning the first content label to the first content feed; and causing the first content label to be displayed concurrently with information identifying the first content feed.
 20. The non-transitory computer readable storage medium of claim 18, wherein the first content feed provides a first plurality of content items, the one or more programs further comprise instructions for: automatically without human intervention: assigning the first content label to the first plurality of content items. 